Overview
Weave supports ingestion of OpenTelemetry compatible trace data through a dedicated endpoint. This endpoint allows you to send OTLP (OpenTelemetry Protocol) formatted trace data directly to your Weave project.Endpoint details
Path:/otel/v1/traces
Method: POST
Content-Type: application/x-protobuf
Authentication
Standard W&B authentication is used. You must have write permissions to the project where you’re sending trace data.Required Headers
project_id: <your_entity>/<your_project_name>
Authorization=Basic <Base64 Encoding of api:$WANDB_API_KEY>
Examples:
You must modify the following fields before you can run the code samples below:WANDB_API_KEY
: You can get this from https://wandb.ai/authorize.- Entity: You can only log traces to the project under an entity that you have access to. You can find your entity name by visiting your W&N dashboard at [https://wandb.ai/home], and checking the Teams field in the left sidebar.
- Project Name: Choose a fun name!
OPENAI_API_KEY
: You can obtain this from the OpenAI dashboard.
OpenInference Instrumentation:
This example shows how to use the OpenAI instrumentation. There are many more available which you can find in the official repository: https://github.com/Arize-ai/openinference First, install the required dependencies:openinference_example.py
OpenLLMetry Instrumentation:
The following example shows how to use the OpenAI instrumentation. Additional examples are available at https://github.com/traceloop/openllmetry/tree/main/packages. First install the required dependencies:openllmetry_example.py
. Note that this is the same code as above, except the OpenAIInstrumentor
is imported from opentelemetry.instrumentation.openai
instead of openinference.instrumentation.openai
Without Instrumentation
If you would prefer to use OTEL directly instead of an instrumentation package, you may do so. Span attributes will be parsed according to the OpenTelemetry semantic conventions described at https://opentelemetry.io/docs/specs/semconv/gen-ai/gen-ai-spans/. First, install the required dependencies:opentelemetry_example.py
gen_ai
and openinference
are used to determine which convention to use, if any, when interpreting the trace. If neither key is detected, then all span attributes are visible in the trace view. The full span is available in the side panel when you select a trace.